## 日本国特許庁 JAPAN PATENT OFFICE

別紙添付の書類に記載されている事項は下記の出願書類に記載されている事項と同一であることを証明する。

This is to certify that the annexed is a true copy of the following application as filed with this Office.

出願年月日 Date of Application:

2003年 4月24日

出 願 番 号
Application Number:

人

特願2003-120600

[ST. 10/C]:

[JP2003-120600]

出 願
Applicant(s):

シャープ株式会社



# CERTIFIED COPY OF PRIORITY DOCUMENT



特許庁長官 Commissioner, Japan Patent Office 2003年12月16日

今井康



【書類名】 特許願

【整理番号】 03J00997

【提出日】 平成15年 4月24日

【あて先】 特許庁長官 殿

【国際特許分類】 G06F 17/50

【発明者】

【住所又は居所】 大阪府大阪市阿倍野区長池町22番22号 シャープ株

式会社内

【氏名】 岡田 和久

【特許出願人】

【識別番号】 000005049

【氏名又は名称】 シャープ株式会社

【代理人】

【識別番号】 100078282

【弁理士】

【氏名又は名称】 山本 秀策

【選任した代理人】

【識別番号】 100062409

【弁理士】

【氏名又は名称】 安村 高明

【選任した代理人】

【識別番号】 100107489

【弁理士】

【氏名又は名称】 大塩 竹志

【手数料の表示】

【予納台帳番号】 001878

【納付金額】 21,000円

【提出物件の目録】

【物件名】 明細書 1

ページ: 2/E

【物件名】 図面 1

【物件名】 要約書 1

【包括委任状番号】 0208587

【プルーフの要否】 要

## 【書類名】 明細書

【発明の名称】 動作合成システム、動作合成方法、制御プログラム、可読記録 媒体、論理回路の製造方法および論理回路

#### 【特許請求の範囲】

【請求項1】 ループ処理および非ループ処理を含む動作記述から、各種処理手段を示す各節点とデータの流れを示す入出力枝によりコントロールデータフローグラフを生成するコントロールデータフローグラフ生成手段と、該コントロールデータフローグラフを用いてレジスタトランスファレベルのハードウェア構成を自動合成する手段とを有した動作合成システムにおいて、

該コントロールデータフローグラフ生成手段は、該ループ処理に含まれる各節点を各パイプライン化ステージ毎に分けて複数回のループ処理の1回毎に該各パイプライン化ステージの処理を並行して実行することを示すコントロールデータフローグラフのループ処理部内に、該ループ処理および非ループ処理のうち少なくとも非ループ処理を行わせる各制御信号をそれぞれステージ毎の各節点にそれぞれ出力可能とするループ制御部が設けられた動作合成システム。

【請求項2】 前記ループ制御部は、前記各制御信号をそれぞれ前記ステージ毎の各節点にそれぞれ出力する複数のポートと、該複数のポートのうち所定の一または複数のポートに接続されて終了判定を行う終了条件比較節点とを有する請求項1または2記載の動作合成システム。

【請求項3】 前記ループ処理部は、所定の入力初期値が入力され、これを 1 サイクル毎にインクリメントした値を順次出力するループ用ポートと、該ループ用ポートからの出力値に対してループ処理の回数が規定回数に達したかどうか を判定する判定出力を前記ループ制御部に出力するループ回数判定節点と、前記 ステージ毎の各節点とを有する相請求項1または2に記載の動作合成システム。

【請求項4】 前記ループ制御部は、前記ループ回数判定節点からの判定出力を受けて、該ループ制御部の各ポートから前記ステージ毎の各節点にそれぞれ、非ループ処理を行わせる各制御信号をそれぞれ出力する請求項3に記載の動作合成システム。

【請求項 5】 前記ループ制御部の複数のポートは、前記パイプライン化ス

2/

テージのステージ段数と同じビット数のシフトレジスタの機能を有している請求 項2に記載の動作合成システム。

【請求項6】 前記複数のポートは、前記ステージ毎の各節点にそれぞれ、前記シフトレジスタ機能によって所定の入力初期値が1サイクル毎に順次シフトされた各制御信号をそれぞれ供給する請求項5に記載の動作合成システム。

【請求項7】 前記ステージ毎の各節点であって、前記ループ処理部の外部 に対して作用する節点に対して、当該節点を前記ループ制御部からの制御信号により制御する請求項1に記載の動作合成システム。

【請求項8】 前記コントロールデータフローグラフ生成手段は、パイプライン化されていないループ処理のコントロールデータフローグラフに基づいて、パイプライン化されたループ処理のコントロールデータフローグラフを生成する請求項1に記載の動作合成システム。

【請求項9】 前記コントロールデータフローグラフ生成手段は、前記パイプライン化されていないループ処理のコントロールデータフローグラフに対して、ステージ境界部分とグラフの枝が交差する箇所に新たにポートを追加するポート追加手段と、並列処理を示すために各ステージを横方向に配置する横方向配置手段と、横方向に配置されたループ処理部の各ステージに対して、繰り返し間データ転送枝を接続処理する枝接続手段と、該ループ処理部内に前記ループ制御部を設けるループ制御部追加手段とを有する請求項8に記載の動作合成システム。

【請求項10】 前記枝接続手段は、ループ処理部外から与えられる初期値 およびループ処理部内で演算された値の何れか一方を選択してループ処理部内の 変数に代入するセレクタ節点を生成し、前記ループ制御部追加手段は、何れの値 が代入されるかが前記ループ制御部の制御信号によって制御されるように、該ル ープ制御部とセレクタ節点とを接続処理する請求項9に記載の動作合成システム

【請求項11】 ループ処理および非ループ処理を含む動作記述から、演算処理手段を示す各節点とデータの流れを示す入出力枝によりコントロールデータフローグラフを生成するコントロールデータフローグラフ生成工程と、該コントロールデータフローグラフを用いてレジスタトランスファレベルのハードウェア

構成を自動合成する工程とを有する動作合成方法において、

該コントロールデータフローグラフ生成工程は、該ループ処理に含まれる各節点を各パイプライン化ステージ毎に分ける工程と、複数回のループ処理の1回毎に該各パイプライン化ステージの処理を並行して実行するループ処理部を生成する工程と、該ループ処理部内に、該ループ処理および非ループ処理のうち少なくとも非ループ処理を行わせる制御信号を該各節点に出力可能とするループ制御部を生成する工程とを有する動作合成方法。

【請求項12】 請求項11に記載の動作合成方法の各処理手順をコンピュータに実行させる制御プログラム。

【請求項13】 請求項12に記載の制御プログラムが記録されたコンピュータ読み取り可能な可読記録媒体。

【請求項14】 請求項1に記載の動作合成システムにより自動合成された 回路構成に基づいて論理回路を製造する論理回路の製造方法。

【請求項15】 複数の論理演算手段による並列演算を繰り返し行うループ処理部内に、ループ処理および非ループ処理のうち少なくとも非ループ処理を行わせる各制御信号をそれぞれ複数の論理演算手段の少なくとも何れかに出力可能とするループ制御部が設けられた論理回路。

## 【発明の詳細な説明】

 $[0\ 0\ 0\ 1\ ]$ 

#### 【発明の属する技術分野】

本発明は、例えば論理回路などの回路設計に用いられ、ループ処理を含む動作記述からパイプライン化されたコントロールデータフローグラフを生成する動作合成システム、これを用いてRTL(Register Transfer Level;レジスタトランスファレベル)の回路を自動合成する動作合成方法、その各処理手順をコンピュータに実行させる制御プログラム、これが記録されたコンピュータ読み取り可能な可読記録媒体、それらを用いた論理回路の製造方法および論理回路に関する

[0002]

【従来の技術】

従来、論理回路を含むシステムLSIなどの大規模回路の設計において、動作 記述からRTLの論理回路を生成する動作合成処理が行われている。

## [0003]

この動作合成処理は、高位合成処理とも言われており、ハードウェアの構造に 関する情報が含まれず、各処理のアルゴリズムのみが記述された動作記述から、 RTLレベルのハードウェア(回路図)が自動的に合成される。

## [0004]

例えば、非特許文献1には、C言語をハードウェア設計用に拡張した言語を動作記述言語として、ハードウェア(回路図)を合成することが可能なコンピュータシステムである動作合成システムが開示されている。

#### [0005]

また、非特許文献2には、従来の動作合成技術の詳細が記載されており、コントロールデータフローグラフ(CDFG)から所望のハードウェア(回路図)を得る処理の詳細について記載されている。

## [0006]

以下に、従来の動作合成技術を用いて、動作記述から所望の回路図を自動的に 合成する動作合成装置による動作合成方法(高位合成方法)について簡単に説明 する。

#### [0007]

この動作合成装置は、コンピュータシステムにて構成され、例えば、後述する 図示しないCDFG生成手段と、スケジューリング処理手段と、アロケーション 処理手段と、データパス生成手段と、コントローラ生成手段とを有しており、図 10の動作合成方法の各処理手順を順次行うことによりRTL (レジスタトラン スファレベル)のハードウェア (回路図)を自動合成 (自動設計) する。

#### [0008]

図10に示すように、まず、ステップS1のコントロールデータフローグラフ (CDFG) 生成では、CDFG生成手段がアルゴリズム記述 (動作記述) におけるデータの流れを解析し、CDFGと称されるモデルを作成する。CDFGは、演算を表す節点と、データの流れを表す枝とによって構成されている。各節点

は、入力枝と出力枝とによって接続されており、入力枝は演算に与えられるデータ、出力枝は演算結果のデータを表す。また、各節点はそれぞれ、演算の種類に 関する情報も有している。

## [0009]

例えば図11に示すC言語で記述された動作記述は、図12に示すCDFGによって表される。

## [0010]

図12のCDFGは、二つの乗算を表す節点1および2と、一つの加算を表す節点3とを含み、節点1で入力データaおよびbが乗算された結果と、節点2で入力データbおよびcが乗算された結果とが、節点3で加算され、その結果が出力データXとして出力されることを表している。

#### [0011]

このCDFGは、コンピュータ(計算機)上では、例えば図13に示すようなデータ構造で表される。

## [0012]

図13のデータ構造では、節点はNode構造体で表され、各節点固有の節点番号node\_idを有している。また、in\_edge配列には入力枝の枝番号が、out\_edge配列には出力枝の枝番号が、複数記憶される。図13の例に示される節点は2入力1出力の演算であり、in\_edgeは二つの要素、out\_edgeは一つの要素を有している。また、op\_typeには加算・減算・乗算などの各種演算の種類を表す番号が記憶されている。

## [0013]

また、枝はEdge構造体で表され、各枝固有の枝番号edge\_idを有している。from\_nodeおよびto\_nodeには、その枝が接続された節点の節点番号が格納されている。

## [0014]

図13のようなデータ構造により、コンピュータ(計算機)上のメモリ内にCDFGの各節点間の接続が記憶されている。

#### [0015]

また、CDFG上で節点を接続する場合や、ある節点の入出力につながる別の 節点を見つける場合には、以上のようにして計算機上のメモリ内に記憶されたデ ータの各要素に節点や枝の番号を登録し、またはそれを参照する。

## [0016]

以下では、説明を分かり易くするために、図12のCDFGを視覚的に表し、 節点を枝で接続したり、節点に枝で接続された別の節点を参照しながら説明を行 う。

#### $[0\ 0\ 1\ 7\ ]$

次に、図10のステップS2およびステップS3の各処理では、ステップS1で生成されたCDFGに対して、スケジューリング処理手段がスケジューリング処理を行い、さらに、アロケーション処理手段がアロケーション処理を行う。

## [0018]

スケジューリング処理では、CDFG中の各節点をいつ実行させるかを決定する処理である。スケジューリング処理は、CDFG中の各節点がいくつかのステップに分けられる。一つのステップに含まれる節点は、クロックの変化の1サイクル中に実行される。

#### [0019]

アロケーション処理はバインディング処理とも言われ、CDFG中の枝で表されるデータを格納するレジスタを決定する処理と、CDFG中の節点で表される演算を、どの演算器を用いて行うかを決定する処理とからなっている。動作合成方法(高位合成方法)によっては、このアロケーション処理がスケジューリング処理の前に行なわれる場合もある。

#### [0020]

次に、図10に示すように、ステップS4およびステップS5の各処理では、スケジューリング結果およびアロケーション結果を元に、データパス生成手段がデータパスを生成し、さらに、コントローラ生成手段がコントローラを生成することによりRTL(レジスタトランスファレベル)のハードウェア(回路図)が自動合成(自動設計)される。このように、CDFGからハードウェア(回路図)を得る処理の詳細については上記非特許文献2に記載されており、また、その

一例が特許文献1に記載されている。

## [0021]

ところで、実際の設計回路では、動作記述中にループ処理が含まれていることが多い。このループ処理は、多数回繰り返して実行されるため、回路全体の処理時間のうち、多くは、ループ処理によって占められる。

#### [0022]

したがって、回路の合成処理を高速化したい場合には、このループ処理を高速化することが有効である。例えば、画像処理や音声処理などのように、ある一定の時間内に処理を終える必要があり、高速性が要求される回路設計の場合には、このようなループ処理の高速化が必須である。

#### [0023]

このようなループ処理の高速化という問題を解決する方法の一つとして、ループ処理をパイプライン化する方法が挙げられる。

#### [0024]

従来のループ処理のパイプライン化方法としては、例えば非特許文献3に開示されているような方法が挙げられ、この方法は例えば特許文献2の図3(e)に 図示されている。

#### [0025]

以下に、従来のループのパイプライン化方法について、図14に示すようなループ処理を含む動作記述を一例として簡単に説明する。図14では、i=0から iを一つづつインクリメントしながら  $i \le 10$ の条件を満たす間、f(i)、g(i)およびh(i)の演算を行うという各処理を表す動作記述である。

#### [0026]

図15は、図14に示す動作記述について、ループ処理をパイプライン化しない場合のCDFGを示す図である。

## [0027]

図15において、矩形10はループ処理部を表し、ループ処理部10内のCD FGが繰り返し実行される。ループ処理部10の上端と下端に示す丸印12および13はループ処理部10のポートを表し、図15の変数iに対応する。ポート 12に格納された変数iの値(データ)がインクリメント演算節点14でインクリメントされて一つ増加するように変化し、ポート13に至る。ポート12と13とは同じ変数を表しており、ポート13に至ったデータは次の繰り返しで再びポート12に戻されて使用されるようになっている。ループ処理部10の外の節点11は定数を出力する節点であり、まず変数iの初期値がポート12に与えられる。

## [0028]

図14の動作記述では、変数iのみがループ処理部10内で繰り返し使用されるが、例えば2個以上の変数がループ処理部内で繰り返し使用される場合には、12および13のようなポートの対が、変数の個数分だけ設けられることになる。

## [0029]

節点15では終了条件の比較が行なわれ、「真( $i \le 10$ )」であれば「1」、「偽」であれば「0」が出力される。

## [0030]

節点16はループ処理部10の終了を制御する特別な「EXIT」節点であり、終了条件比較節点15からの入力データが「0」の場合(変数iが10以下の場合)には、図示しないコントローラに対してループ10の処理を終了し、次の状態に移行するように指示が行われる。

#### [0031]

節点 1.7、1.8 および 1.9 ではそれぞれ、図 1.4 の動作記述中の関数 f、 g および h の各種演算処理が行われる。それぞれの節点 1.7、1.8 および 1.9 には、変数 i の値が入力されている。節点 1.7、1.8 および 1.9 はそれぞれ、ステップ 1.2 および 3 にスケジューリングされている。

#### [0032]

上記構成により、その処理動作を説明すると、クロックの1サイクル目で、1回目のループ処理のステップ1に含まれる節点17で演算f、即ちf(1)が実行され、2サイクル目で、1回目のループ処理のステップ2に含まれる節点18で演算g、即ちg(1)が実行され、3サイクル目で、1回目のループ処理のス

テップ3に含まれる節点19で演算h、即ちh(1)が実行される。

#### [0033]

次に、4、5および6サイクル目で、2回目のループ処理のステップ1、2および3に含まれる節点17、18および19でf(2)、g(2)およびh(2) がそれぞれ順次実行される。したがって、ループ処理を10回繰り返しすためには、30サイクルの処理が必要となる。

## [0034]

なお、CDFGでループ処理を表す方法には、決まった形式がなく、各文献毎に様々な表記がされているが、動作としては同一である。

## [0035]

次に、図14の動作記述のループ処理をパイプライン化する場合について説明 する。

#### [0036]

ここでは、ループ処理のパイプライン化段数は3段とする。したがって、ループ処理を1回繰り返すときの処理を3ステージに分ける。なお、ステージとは、パイプライン動作をする場合の処理のまとまりのことである。

#### [0037]

図14の動作記述のループ処理は、パイプライン化されない場合には、1回の繰り返しが3ステップにスケジューリングされるだけであるので、3ステージに分けるためには、ループ処理の1ステップが1ステージ、2ステップが2ステージ、3ステップが3ステージに割り当てられる。

#### [0038]

また、例えばパイプライン化されないループ処理が4ステップにスケジューリングされ、それを2ステージに分ける場合には、1および2ステップが1ステージに、3および4ステップが2ステージに割り当てられる。この場合、1ステージを実行するために2サイクルが必要となる。

#### [0039]

パイプライン化された回路では、図16に示すような各処理動作が行われる。

#### [0040]

図16に示すように、まず、クロックの1サイクル目ではf(1)のみが実行される。次に、2サイクル目では、g(1)が実行されるのと同時に、2回目のループ処理の繰り返しが開始されてf(2)が実行される。さらに、3サイクル目では、h(1)が実行されて1回目のループ処理の繰り返しが終了するのと同時に、2回目の繰り返しのg(2)と3回目の繰り返しのf(3)とが同時に実行される。以降、kサイクル目ではh(k-2)、g(k-1)およびf(k)が同時に実行される。さらに、11サイクル目ではh(9)とg(10)が、12サイクル目ではh(10)のみが実行されて、10ののののののののののでは11のののののののでは12のののののののでは11ののののののののでは11のののののののでは11のののののののののでは11のののののののののでは11ののののののののでは11ののののののののでは11のののののののでは11のののののののでは11ののののののでは11のののののでは11のののののでは11のののののでは11ののののでは11ののののでは11ののののでは11ののののでは11ののののでは11のののののでは11ののののでは11のののでは11のののでは11のののでは11のののでは11のののでは11のののでは11のののでは11のののでは11ののでは11ののでは11ののでは11ののでは11ののでは11ののでは11ののでは11ののでは11ののでは11ののでは11ののでは11ののでは11ののでは11ののでは11ののでは11ののでは11ののでは11ののでは11ののでは11ののでは11ののでは11ののでは11ののでは11ののでは11ののでは11ののでは11ののでは11ののでは11のでは11のでは11ののでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは11のでは

## [0041]

このように、図14の動作記述を実行するために、ループ処理がパイプライン 化されない場合には30サイクル必要であったが、ループ処理がパイプライン化 された場合には12サイクルでよい。

## [0042]

図14の動作記述のループ処理を、従来の方法によってパイプライン化した場合のCDFGを図17に示している。図17のCDFGでは、スケジューリングも行われており、各節点が各ステップに分けられている。

#### [0043]

図17に示すように、CDFGにおいて、ステップ1ではf(1)のみが実行され、ステップ2ではg(1)とf(2)とが同時に実行される。

#### [0044]

次に、ステップ3に含まれるループ処理部21の処理に進む。なお、このループ処理部21では、1回の処理を繰り返すために1サイクルを必要とし、ループ処理の繰り返し回数に応じたサイクル数を必要とする。したがって、ステップ4の処理以降は、ステップ数とサイクル数とは異なる。

#### [0045]

)および h (1) が同時に実行される。また、2回目のループ処理では、f (4)、g (3) および h (2) が同時に実行され、3回目から7回目のループ処理が実行された後、8回目のループ処理では、f (10)、g (9) および h (8) が同時に実行される。節点28で条件(10以下)が比較され、その条件に一致した場合にループ処理部21の処理が終了され、次のステップ4の処理へと進む。

## [0046]

さらに、ステップ4ではg(10)およびh(9)が実行され、更に次のステップ5ではh(10)のみが実行される。

## [0047]

図17のCDFG中、ループ処理部21の本体に対して、その前に実行される部分20の処理はプロローグ部と言われ、その後に実行される部分29の処理部はエピローグ部と言われている。

#### [0048]

このようなCDFGを作成することによって、ループ処理をパイプライン化して、より高速に処理することが可能となる。

#### [0049]

## 【非特許文献1】

"A C-based Synthesis System, Bach, and its Application" Proceedings of the ASP-DAC 2001, 2001 (IEEE Catalog Number: 01EX455, ISBN: 0-7803-6633-6)

#### 【非特許文献2】

"High Level Synthesis," Kluwer Academic Publishers, 1992 (ISBN: 0-7923-91 94-2)

#### 【非特許文献3】

"Percolation Based Synthesis" Proceedings of Design AutomationConferen

ce 1990, pp. 444-448 (IEEE)

## 【特許文献1】

特開2001-229217号公報

## 【特許文献2】

特開2001-142937号公報(図3(e))

## [0050]

## 【発明が解決しようとする課題】

しかしながら、図17に示すように、従来の方法でループ処理をパイプライン化した場合には、CDFG中のループ処理部の前後にそれぞれプロローグ部とエピローグ部とがそれぞれ必要とされ、CDFGが複雑化する。このため、このCDFGからハードウェア(回路図)を動作合成すると、生成されるハードウェアの面積が大きくなり、チップの製造コストが高くなるという問題がある。

#### [0051]

また、このような従来の方法でループ処理をパイプライン化したCDFGでは、プロローグ部とエピローグ部とは、ループ繰り返しの条件判断が行われずに必ず実行されてしまう。このため、プロローグ部の実行が終了する前にループ自体が終了してしまう場合には、正しい動作が行われなくなる。例えば、図14の動作記述の場合、ループ処理の繰り返し回数を1回とするためには、f(1)、g(1) およびh(1) のみを実行する必要があるが、2 サイクル目でf(2) が実行されてしまう。例えば、f(2) の処理がメモリへの書き込みや外部との通信を行うという処理を含む場合には、メモリに誤った値が書き込まれたり、外部に不要な値が送出されたりするため、回路が誤動作するという問題がある。

#### [0052]

このような誤動作を防ぐために、ループ処理の繰り返し回数が少ない場合を別に場合分けしたCDFGを導入することも考えられるが、この場合には、さらにCDFGが複雑化し、ハードウェア(回路図)面積が大きくなるという問題がある。

#### [0053]

本発明は、上記従来の問題を解決するもので、従来のプロローグ部やエピロー

グ部を必要とせず、ハードウェアの面積増大とコスト増加を防ぐことができる動作合成システム、これを用いた動作合成方法、その各処理手順をコンピュータに実行させる制御プログラム、これが記録されたコンピュータ読み取り可能な可読記録媒体、それらを用いた論理回路の製造方法および論理回路を提供することを目的とする。

## [0054]

## 【課題を解決するための手段】

本発明の動作合成システムは、ループ処理および非ループ処理を含む動作記述から、各種処理手段を示す各節点とデータの流れを示す入出力枝によりコントロールデータフローグラフを生成するコントロールデータフローグラフ生成手段と、このコントロールデータフローグラフを用いてレジスタトランスファレベルのハードウェア構成を自動合成する手段とを有した動作合成システムにおいて、コントロールデータフローグラフ生成手段は、ループ処理に含まれる各節点を各パイプライン化ステージ毎に分けて複数回のループ処理の1回毎に各パイプライン化ステージの処理を並行して実行することを示すコントロールデータフローグラフのループ処理部内に、ループ処理および非ループ処理のうち少なくとも非ループ処理を行わせる各制御信号をそれぞれステージ毎の各節点にそれぞれ出力可能とするループ制御部が設けられたものであり、そのことにより上記目的が達成される。

#### [0055]

また、好ましくは、本発明の動作合成システムにおけるループ制御部は、各制 御信号をそれぞれステージ毎の各節点にそれぞれ出力する複数のポートと、複数 のポートのうち所定の一または複数のポートに接続されて終了判定を行う終了条 件比較節点とを有する。

#### [0056]

さらに、好ましくは、本発明の動作合成システムにおけるループ処理部は、所 定の入力初期値が入力され、これを1サイクル毎にインクリメントした値を順次 出力するループ用ポートと、ループ用ポートからの出力値に対してループ処理の 回数が規定回数に達したかどうかを判定する判定出力をループ制御部に出力する ループ回数判定節点と、ステージ毎の各節点とを有する。

## [0057]

さらに、好ましくは、本発明の動作合成システムにおけるループ制御部は、ループ回数判定節点からの判定出力を受けて、ループ制御部の各ポートからステージ毎の各節点にそれぞれ、非ループ処理を行わせる各制御信号をそれぞれ出力する。

## [0058]

さらに、好ましくは、本発明の動作合成システムにおいて、ループ制御部の複数のポートは、パイプライン化ステージのステージ段数と同じビット数のシフトレジスタ機能を有している。

#### [0059]

さらに、好ましくは、本発明の動作合成システムにおける複数のポートは、ステージ毎の各節点にそれぞれ、シフトレジスタ機能によって所定の入力初期値が 1 サイクル毎に順次シフトされた各制御信号をそれぞれ供給する。

## [0060]

さらに、好ましくは、本発明の動作合成システムにおいて、ステージ毎の各節点であって、ループ処理部の外部に対して作用する節点に対して、この節点をループ制御部からの制御信号により制御する。

#### $[0\ 0\ 6\ 1]$

さらに、好ましくは、本発明の動作合成システムにおけるコントロールデータフローグラフ生成手段は、パイプライン化されていないループ処理のコントロールデータフローグラフに基づいて、パイプライン化されたループ処理のコントロールデータフローグラフを生成する。

#### [0062]

さらに、好ましくは、本発明の動作合成システムにおけるコントロールデータフローグラフ生成手段は、パイプライン化されていないループ処理のコントロールデータフローグラフに対して、ステージ境界部分とグラフの枝が交差する箇所に新たにポートを追加するポート追加手段と、並列処理を示すために各ステージを横方向に配置する横方向配置手段と、横方向に配置されたループ処理部の各ス

テージに対して、繰り返し間データ転送枝を接続処理する枝接続手段と、ループ 処理部内にループ制御部を設けるループ制御部追加手段とを有する。

## [0063]

さらに、好ましくは、本発明の動作合成システムにおける枝接続手段は、ループ処理部外から与えられる初期値およびループ処理部内で演算された値の何れか一方を選択してループ処理部内の変数に代入するセレクタ節点を生成し、ループ制御部追加手段は、その何れの値が代入されるかがループ制御部の制御信号によって制御されるように、ループ制御部とセレクタ節点とを接続処理する。

## [0064]

本発明の動作合成方法は、ループ処理および非ループ処理を含む動作記述から、演算処理手段を示す各節点とデータの流れを示す入出力枝によりコントロールデータフローグラフを生成するコントロールデータフローグラフ生成工程と、このコントロールデータフローグラフを用いてレジスタトランスファレベルのハードウェア構成を自動合成する工程とを有する動作合成方法において、コントロールデータフローグラフ生成工程は、ループ処理に含まれる各節点を各パイプライン化ステージ毎に分ける工程と、複数回のループ処理の1回毎に各パイプライン化ステージの処理を並行して実行するループ処理部を生成する工程と、ループ処理部内に、ループ処理および非ループ処理のうち少なくとも非ループ処理を行わせる制御信号を該各節点に出力可能とするループ制御部を生成する工程とを有するものであり、そのことにより上記目的が達成される。

## [0065]

本発明の制御プログラムは、請求項11に記載の動作合成方法の各処理手順を コンピュータに実行させるものであり、そのことにより上記目的が達成される。

## [0066]

本発明の可読記録媒体は、請求項12に記載の制御プログラムが記録されたコンピュータ読み取り可能なものであり、そのことにより上記目的が達成される。

#### [0067]

本発明の論理回路の製造方法は、請求項1に記載の動作合成システムにより自動合成された回路構成に基づいて論理回路を製造するものであり、そのことによ

り上記目的が達成される。

## [0068]

本発明の論理回路は、複数の論理演算手段による並列演算を繰り返し行うループ処理部内に、ループ処理および非ループ処理のうち少なくとも非ループ処理を 行わせる各制御信号をそれぞれ複数の論理演算手段の少なくとも何れかに出力可能とするループ制御部が設けられており、そのことにより上記目的が達成される

## [0069]

上記構成により、以下に、本発明の作用について説明する。

## [0070]

本発明にあっては、ループ処理および非ループ処理が含まれている動作記述から、パイプライン化されたCDFGを生成する際に、ループ処理に含まれる各節点を各パイプライン化ステージ毎に分けて複数回のループ処理の1回毎に各パイプライン化ステージの処理を並行して実行することを示すコントロールデータフローグラフのループ処理部内に、ループ処理および非ループ処理のうち少なくとも非ループ処理を行わせる制御信号を各節点に出力するループ制御部が設けられている。

## [0071]

一方、従来の構成では、ループ処理をパイプライン化する場合に、その前後の プロローグ部とエピローグ部とが条件判断無しに必ず実行されるため、プロロー グ部の実行が終了する前にループ処理が終了すると、正しい動作が行われないお それがある。また、プロローグ部とエピローグ部とがループ処理部とは別に設け られているため、ハードウェアの面積が大きくなる。

#### [0072]

本発明では、プロローグ部とエピローグ部との機能をループ制御部としてループ処理部内に含めたため、従来のようにプロローグ部とエピローグ部とをループ処理部とは別に設ける必要がなく、誤動作やチップ面積増大を防ぐことができる

#### [0073]

また、単純な動作記述の場合には、パイプライン化されたCDFGを作成することは容易であるが、動作記述が複雑である場合には、パイプライン化されたCDFGを作成することは困難である。このような場合には、パイプライン化されていないループ処理のCDFGを変形してパイプライン化されたループ処理のCDFGを作成することが有効である。

#### [0074]

ループ処理部内に含まれる節点のうち、ループ処理の外部に対して作用しない 節点は、実行されても実行されなくても問題が生じないが、外部に対して作用す る節点では、誤動作が生じるおそれがある。したがって、そのような外部に対し て作用する節点では、ループ制御部からの出力制御信号によって制御する。

## [0075]

また、ループ処理部の外から与えられる初期値およびループ処理部内で演算された値のいずれか一方を選択してループ処理部内の変数に代入するセレクタ節点においても、いずれの値を代入するかをループ制御部の出力制御信号によって制御する。

#### [0076]

さらに、ループ処理および非ループ処理の終了判定についても、ループ制御部 からの出力制御信号によって制御することができる。

#### [0077]

本発明によって設計された論理回路図に基づいて製造された論理回路は、ループ制御部が設けられているので、ループ処理部で誤動作が生じることなく、また、プロローグ部やエピローグ部が不要であるためチップ面積を縮小化することができる。

## [0078]

#### 【発明の実施の形態】

以下、本発明の動作合成システムの実施形態について、図面を参照しながら説明する。

#### [0079]

図1は、本発明の動作合成システムの実施形態における要部構成を示すブロッ

ク図である。

## [080]

図1において、動作合成システム100は、コンピュータシステムにて構成され、各部を制御して制御プログラムを実行する制御部111と、制御プログラムおよびそのデータなどが記録されたROM112と、制御部111の制御時にワークメモリとして働くRAM113と、回路設計に必要な各種データが記録されたデータベース114と、ユーザによる操作指令入力を可能とする操作部115と、各種画像表示が為される表示部116とを有し、ループ処理および非ループ処理を含むアルゴリズムが記録された動作記述から、演算処理を示す節点とデータの流れを示す入出力枝により生成されたコントロールデータフローグラフを用いて、RTL(レジスタトランスファレベル)の所望のハードウェア(回路図)を自動合成(自動設計)する。この場合、ROM112には、FDやCD(光ディスク)などの可読記録媒体から制御プログラムおよびそのデータがインストールされている。

## [0081]

制御部111はCPU(中央演算処理装置)で構成されており、制御プログラムに基づいて、CDFG生成手段111Aと、スケジューリング処理手段111 Bと、アロケーション処理手段111Cと、データパス生成手段111Dと、コントローラ生成手段111Eとによる各機能を順次実行するようになっている。

#### [0082]

CDFG生成手段111Aは、アルゴリズム記述(動作記述)におけるデータの流れを解析し、演算などの各種処理機能を表す節点と、データの流れを表す枝とによって構成されるCDFGと称されるモデルを作成する。入力枝は演算などの各種処理機能に与えられるデータ、出力枝は演算結果のデータを表す。また、各節点はそれぞれ、演算の種類に関する情報も有している。また、CDFG生成手段111Aは、ループ処理に含まれる各節点を各パイプライン化ステージに分け1回毎のループ処理に対して各パイプライン化ステージの各処理を並行して実行するようにしたCDFGのループ処理部内に、ループ処理が行われないときに非ループ処理を行わせる制御信号を各節点に出力可能とするループ制御部が設け

られる構成である。即ち、ループ処理部内にループ制御部が設けられており、C DFGはループ処理部とループ制御部とを有する。

#### [0083]

スケジューリング処理手段111Bは、CDFG中の各節点をいつ実行させるかを決定する処理である。スケジューリング処理手段111Bは、CDFG中の各節点をいくつかのステップに分ける。一つのステップに含まれる節点は、クロック変化の1サイクル中に実行される。

## [0084]

アロケーション処理手段111Cは、CDFG中の枝で表されるデータを格納するレジスタを決定するレジスタ決定手段と、CDFG中の節点で表される演算機能を、どの演算器を用いて行うかを決定する演算器決定手段とを有している。なお、動作合成システムによっては、このアロケーション処理手段111Cによる処理がスケジューリング処理手段111Bによる処理前に行われる場合もある。

## [0085]

データパス生成手段111Dはデータパスを生成する。

#### [0086]

コントローラ生成手段 1 1 1 E はコントローラを生成する。これによって、R T L (レジスタトランスファレベル) のハードウェア (回路図) が自動合成 (自動設計) される。

#### [0087]

以下に、本発明のCDFG生成手段111Aにおけるループ処理のパイプライン化方法の各実施形態1,2について図面を参照しながら詳細に説明する。

#### [0088]

#### (実施形態1)

本実施形態1では、図14の動作記述に対して、本発明のループ処理のパイプ ライン化方法を適用した例について説明する。

## [0089]

図2は、図14の動作記述に対して、本実施形態1のループのパイプライン化

方法によりループをパイプライン化したCDFGを示す図である。

#### [0090]

図2のCDFGでは、図17に示す従来の方法によるCDFGから、プロローグ部20とエピローグ部29とからなる非ループ処理が削除され、ループ処理を構成する各パイプライン化ステージに対して、その節点(演算処理手段)のループ処理と非ループ処理と制御する制御信号V1~V3を出力するループ制御部31がループ処理部30に設けられている。このループ制御部31からの出力信号線(出力枝)はそれぞれ、ループ処理部30を構成する各ステージ内で演算処理を行う節点に接続されている。また、繰り返し変数「i」の初期値を与える節点41の値は「1」に設定されている。

## [0091]

ここで、まず、ループ処理部30におけるループ制御部31について詳細に説明する。

#### [0092]

図2において、ループ制御部31には、パイプライン段数分の個数のループ制御変数が設けられている。この図2の例では、パイプライン段数が3段であるため、三つのループ制御変数V1、V2およびV3が設けられており、それぞれ、ポート35、36および37に対応している。これらのループ制御変数V1、V2およびV3は全て、「0|または「1|を表す1ビットの変数である。

## [0093]

制御変数V1はループ処理をパイプライン化したときにステージ1に含まれる処理を制御するための制御信号として作用するものであり、制御変数V2はステージ2に含まれる処理を制御する制御信号として作用するものであって、制御変数V3はステージ3に含まれる処理を制御する制御信号として作用するものである。

#### [0094]

制御変数V1には初期値「1」が節点32から与えられ、それ以外のループ制御変数V2およびV3には初期値「0」が節点33および34からそれぞれ与えられる。また、ループ制御部31では、制御変数V1およびV2の値が、次の繰

り返しではV2およびV3に転送されるように、ポート35はポート39へ、ポート36はポート40に接続されている。このループ制御部31のCDFGは、1ビットのレジスタを三つ直列に接続した構成と同様の構成になっており、ハードウェア(回路図)としては3ビットのシフトレジスタによって実現される。また、ポート38には、比較節点43から終了条件の比較結果出力が入力されるようになっている。

#### [0095]

また、クロックの各サイクルにおいて、V1、V2およびV3の値は、図2に示すように、V1が「1」のときにのみ節点46でfの演算処理が実行されるように、V2が「1」のときにのみ節点47でgの演算処理が実行されるように、また、V3が「1」のときにのみ節点48でhの演算処理が実行されるように、ポート35、36および37と各節点46、47および48がそれぞれ接続され、各節点46、47および48が制御変数V1、V2およびV3によってそれぞれ駆動制御されるようになっている。これにより、演算f、gおよびf0が、f05に示す回数と同じ回数だけ、行われるように制御することが可能となる。

#### [0096]

次に、節点49について説明を行う。

#### [0097]

節点49は、ポート36および37に接続され、制御変数 V 2 および V 3 が入力されて、V 2 が「0」、かつ、V 3 が「1」の場合に、ループ処理部30の処理を終了するように図示しないコントローラに処理終了指示が与えられるようになっている。したがって、図3に示すサイクル12で全処理が終了する。

#### [0098]

節点43において、ループ処理の回数が規定回数に達したか否かが判定されるのはサイクル10であるが、その後も、図17に示すようなエピローグ部29に相当する回数分(2サイクル分)だけ、ループ処理部30にて処理が続行されるようになっている。ループ処理としては10回で終了している。

## [0099]

この方法によれば、ループの処理回数が固定値とされていない場合についても

、全く同様に、エピローグ部(非ループ処理)も含めた正しい実行回数だけ、ループ処理および非ループ処理を含む処理を実行することができる。

## [0100]

図2に示すCDFGにおいて、ループ変数iの初期値を与える節点41の値は 1に設定されている。これは、図17に示すプロローグ部20で実行されるi= 1、2のときの処理も、ループ処理部30の本体内で行うためである。

## [0101]

図14の動作記述において、ループ処理は10回繰り返されるが、C言語のwhileループのように、ループを再度繰り返すか否かをループ内の条件式で判断する場合には、ループが1度だけ実行されて終了する場合も考えられる。例えば、図1に示すCDFGの節点43が別の比較式で表され、ループの1回目の実行で「偽」になるような場合には、1サイクル目で、ポート38に「0」が入力される。

#### [0102]

この場合、V1、V2およびV3は図4のように変化し、3サイクル目で節点49において、ループの実行が終了される。図4では、V1、V2およびV3は、それぞれ、1サイクルの間だけ1となり、関数f、gおよびhの演算は、それぞれ1度ずつ実行されることになる。

#### [0103]

このようにして、本実施形態1のループ制御部31を用いることによって、ループの繰り返し回数が小さい場合についても、正しく回路を動作させることができるようになる。

#### [0104]

次に、ループ処理部30の節点46、47および48について説明を行う。

## [0105]

節点46には、二つの値が入力されている。一つはポート42からのiの値であり、もう一つはポート35からのV1の値である。節点46は、V1の値が「1|のときにのみ、f(i)の処理を実行するようになっている。

## [0106]

ここで、f が加算や乗算など、その結果が外部に対して作用しない処理の場合には、V1 の値が「0」のときに f を実行したとしても、その演算結果が使用されないだけであり、実害は生じない。したがって、このような場合には、V1 によって節点 46 の実行を制御する必要はなく、図17 の節点 25 の場合と同様に、常に f の処理を実行する節点としてもよい。

## $[0\ 1\ 0\ 7]$

一方、fがメモリ書き込みや通信など、外部に対して作用する処理の場合には、V1が「1」のときのみ、その処理が実行されるようにする必要がある。V1が「0」のときにfの処理が実行されると、外部からみたときにループの振舞いが変わってしまうからである。

## [0108]

具体的には、メモリ書き込みの場合にはイネーブル信号に対してV1との論理 積を求め、通信の場合には通信要求信号に対してV1との論理積を求めるという ような、簡単な回路を追加することによって対応することができる。以上のこと は節点47および48についても、節点46の場合と同様である。

#### [0109]

次に、節点50および51について説明を行う。

#### [0110]

この節点 50 および 51 は、 f(i) の処理に並行して、 g(i-1) および h(i-2) の処理を行うために設けられている。例えば、 f(3) と同時に g(2) および h(1) が実行される。 i が「1」のときには、ループ制御変数 V(2) と V(3) が「V(3) であるため、 V(3) が実行されるごとはない。

#### $[0\ 1\ 1\ 1]$

なお、上述したように、gおよびhがループ外に対して作用しない処理である場合には、g(0)およびh(-1)が実行されても何ら実害は生じないため、ループ制御変数V2およびV3によって制御する必要もない。

#### [0112]

また、iが12の場合には、V1およびV2が「0」であるため、h(10)

のみが実行され、f(12)およびg(11)は実行されない。同様に、fおよびgが外部に対して作用しない処理であれば、f(12)およびg(11)を実行してもよい。

## [0113]

## (実施形態2)

本実施形態2では、図5の動作記述に対して、本発明のループ処理のパイプライン化方法を適用した例について説明する。

## [0114]

図5はループ処理を含む動作記述の他の例を示す図である。図5において、この動作記述は、i=0からiを一づつインクリメントしながらi<i0の条件を満たす間、配列aに対してi0を書き込み、i2i5を加算した結果を配列i6に対して書き込むという処理を表している。i6の初期値はi7であり、次の繰り返しではi1i7がi2i7として用いられる。

## [0115]

図6は、図5の動作記述について、ループ処理をパイプライン化していない場合のCDFGを示す図である。

#### [0116]

図6において、矩形60はループ(ループ処理部60)を表し、ループ処理部60内のCDFGが繰り返し実行される。矩形60の上端に示すポート63および64はそれぞれ変数iおよびjの値を表している。ポート63に格納された変数iの値は、インクリメント演算節点67でインクリメントされて+1加えられた値となり、枝71を介してポート73に至る。ポート73に至ったデータは、次の繰り返しで再びポート63に戻されて変数iとして使用される。

#### [0117]

節点 65では終了条件の比較が行われ、真( $i \le 10$ )であれば「1」、偽であれば「0」が出力される。また、節点 66では、入力が「0」の場合に、図示しないコントローラに対してループ処理部 60の処理を終了し、次の状態に移行するように指示が与えられる。

## [0118]

節点61および62は定数を出力する節点であり、ループ変数iおよびjの初期値「0」および「5」が与えられる。これらの値はループ処理部60の1回目の繰り返しで用いられ、2回目の繰り返し以降は、ポート73および74の値が用いられる。

## [0119]

節点68は、配列aに対する書き込みを表す。この節点68には、二つの入力が設けられており、左側の入力は配列のインデックス、右側の入力は書き込まれるデータを表す。ここでは、変数iが配列aに書き込まれる。また、節点69は、加算を表し、二つの入力iおよびjの値が加算される。その加算結果は、枝72を介してポート74に至り、次の繰り返しで再びポート64に戻されて変数jとして使用される。節点70は、配列bに対する書き込みを表し、左側の入力は配列のインデックス、右側の入力は書き込まれるデータを表す。ここでは、節点69からの加算結果が配列bに書き込まれる。

#### [0120]

図6のCDFGにおいて、節点67および68はステップ1に、節点69はステップ2に、節点70はステップ3に、それぞれスケジューリングされている。

#### $[0 \ 1 \ 2 \ 1]$

このスケジューリングの場合、1回の繰り返しのために3サイクルを要し、ループを10回繰り返すには30サイクル必要である。したがって、ループを10回繰り返すためには、30サイクルが必要となる。

## [0122]

ところで、図14のような単純な動作記述の場合には、図1に示すようなパイプライン化されたCDFGを作成することは比較的容易であるが、図5に示す動作記述のように、各ステップ間でデータの受け渡しがあるような場合には、次の繰り返しへのデータ受け渡しも考慮して、パイプライン化されたときのデータの受け渡しを決定する必要があるため、複雑である。

#### $[0 \ 1 \ 2 \ 3]$

このような場合には、図6に示すパイプライン化していない場合のループ処理のCDFGを元に、パイプライン化されたループのCDFGを作成する方法が有

効である。この方法について、図7を用いて説明する。

## [0124]

図7は、本実施形態2のCDFGのパイプライン化処理手順を示すフローチャートである。

## [0125]

コンピュータ(計算)上のデータベース114に記憶されたパイプライン化されていないループ処理を含むCDFGに対して、図7に示すような方法をプログラム化して適用することによって、パイプライン化されたループ処理のCDFGをコンピュータ(計算機)上(例えばCDFG生成手段111A)で自動的に生成することが可能となる。

#### [0126]

以下に、図7に示すループ処理のパイプライン化方法の各ステップについて説明する。この例でも、パイプライン段数は「3」としている。

## [0127]

まず、ステップS11の前処理では、図6に示すパイプライン化されていない CDFGに対して、図8Aに示すように、ステージの境界部分とグラフの枝が交差する箇所に新たにポート81、82、83および84を追加する。パイプライン段数は3であるため、図6のステップ $1\sim3$ は、それぞれ、図8Aのステージ $1\sim3$ に対応する。

#### [0128]

ここで、図6に示すループ処理の繰り返し用ポート73および74に接続されている枝71および72は、ループの次の繰り返しへのデータ転送のために用いられる枝である。

#### [0129]

次のステップS12では、同一繰り返し内でのデータ転送についてのみ考慮されるため、枝71および72は、ここでは一旦削除される。この枝71および7 2については、ステップS13で考慮されるようになっている。

#### [0130]

次に、ステップS12のデータフローグラフの変形処理では、各ステージの処

理が並列に動作するように、ステップS11で前処理された各ステージ内のCD FGを、図8Bに示すように、横に並べる。図8Bの例では、ステージ1からス テージ3が左から右へと並べられている。

## [0131]

図8Bにおいて、ポート63および64はそれぞれ、変数iおよびjに対応する。パイプライン化前の図8Aにおいて、枝85はポート63と81とを接続しており、ポート83のデータは、次のサイクルでポート81から使用される。

## [0132]

これに対して、パイプライン化された図8Bでは、ポート63の値は、次のループの繰り返しでポート81に転送される必要がある。そのため、図8Bにおいては、枝85aによって、ポート63が、ポート81ではなく、ポート81aに接続されている。これにより、ポート63の変数iの値は、次の繰り返しでポート81aからポート81に転送され、節点69に入力されることになる。

#### [0133]

その他の枝についても同様に、次のループの繰り返しでデータが転送されるようにポートが接続される。例えば、図8Aのポート64と82とを接続する枝86は、図8Bではポート64と82aとを接続する枝86aとされている。また、図8Aでポート81と83とを接続する枝87は、図8Bではポート81とポート83aとを接続する枝87aとされ、図8Aで節点69とポート84とを接続する枝88は、図8Bでは節点69とポート84aとを接続する枝88aとされている。

## [0134]

次に、ステップS13の繰り返し間データ転送枝の接続処理では、図6に示す ループ処理の繰り返し用ポートに接続されている枝71および72に相当する枝 71aおよび72aを、図8Cに示すように接続する。

#### [0135]

この場合、図6に示すパイプライン化されないCDFGにおいて、枝に対して データを出力する節点と、そのデータを次の繰り返しで使用する節点のステージ の差を考慮する。

## [0136]

図9は、二つの節点のステージの差に応じて、どのようにパイプライン化すればよいかを示す図である。

#### [0137]

図9(a)では、ループがパイプライン化されないときに、データが出力されるB節点102とデータが入力されるA節点101とが同一ステージに含まれている場合を示している。このCDFGがパイプライン化されると、1ステージが1サイクルで実行される場合、各ステージは毎サイクル実行されることになるため、B節点102の処理が実行されて生成されたデータは、1クロックサイクル後に、ループの次の繰り返しのA節点101で使われることになる。これによって、図9(b)に示すパイプライン化されたCDFGでは、B節点102から出力されたデータが、次のループの繰り返しでA節点に入力されて利用されるように、B節点102をポート104に接続し、次のループの繰り返しでポート104に接続し、次のループの繰り返しでポート104に接続する。

## [0138]

一方、図9(c)は、ループがパイプライン化されないときに、データが出力されるB節点102がデータが入力されるA節点101よりも1ステージ前にスケジューリングされている場合を示している。このCDFGがパイプライン化されると、B節点102の処理が実行されて生成されたデータは、2クロックサイクル後に、ループの次の繰り返しのA節点101で使われることになる。これによって、図9(d)に示すパイプライン化されたCDFGでは、B節点102から出力されたデータが、ループを2回繰り返した後にA節点101に入力されて利用されるように、B節点102を次のステップのポート107に接続し、ポート107からのデータが次のループの繰り返しで入力されるポート105をポート108に接続し、ポート108からのデータが次のループの繰り返しで入力されるポート106にA節点101を接続する。

#### [0139]

これと同様に、節点Bが節点Aのnステージ前にスケジューリングされている 場合には、ループをn+1回繰り返した後でデータが使用されるように、図9( d) に示すポート105および108のような繰り返しを追加する。

## [0140]

さらに、図9(e)は、ループがパイプライン化されないときに、データが出力されるB節点102がデータが入力されるA節点101よりも1ステージ後にスケジューリングされている場合を示している。このCDFGがパイプライン化されると、B節点102と次のループの繰り返しの節点A101とは、同一のクロックサイクルで実行される。これによって、図9(f)に示すパイプライン化されたCDFGでは、B節点102とA節点101とが直接接続される。

#### [0141]

なお、パイプライン化されないときに、データが出力するB節点102がデータが入力されるA節点101よりも2ステージ以上後にスケジューリングされている場合には、ループをパイプライン化すること自体が不可能であるため、ここでは考えないこととする。

#### [0142]

例えば図6に示す枝71の場合、その枝に対してデータを出力する節点は節点67であり、そのデータを次の繰り返して使用する節点も節点67であるため、実行されるステージの差は「0」である。したがって、図9(b)に示すように枝を接続すればよい。ここでは、図8Cに示すように、ポート63、節点67および83aが枝71aによって接続されている。

#### [0143]

また、枝72の場合にも、その枝に対してデータを出力する節点は節点69であり、そのデータを次の繰り返しで使用する節点も節点70であるため、ステージの差は「0」である。したがって、図9(b)に示すように枝を接続すれば良いが、この場合には、接続先のポート82aに別の枝86aが接続されている。このため、図8Cに示すように、セレクタ節点89を挿入して枝72aを接続する。このセレクタ節点89は、1サイクル目のみ、ポート64の値を出力し、それ以外は節点69の演算結果をポート82aに出力するようにコントロールされる。ポート64には、図5に示す動作記述の変数 j の初期値が入力されており、最初のループの繰り返しでは j の初期値が使用され、それ以降はループ内部で演

算された値である節点69からの出力が使用される。

#### [0144]

次に、図7のステップS14のループ制御部の追加処理では、図8Dに示すように、CDFGにループ制御部90が加えられる。

#### [0145]

図8Dにおいて、図6のCDFGが3段にパイプライン化されるため、三つのループ制御変数V1、V2およびV3が必要であり、ポート91、92およびV3から、V1、V2およびV3がそれぞれ出力される。

## [0146]

制御変数V1は、ループがパイプライン化されたときにステージ1に含まれる処理を制御する制御信号であり、制御変数V2は、ステージ2に含まれる処理を制御する制御信号であり、制御変数V3は、ステージ3に含まれる処理を制御する制御信号である。制御変数V1は、初期値として1が与えられ、制御変数V2 およびV3は、初期値として0が与えられる。

## [0147]

制御変数V1およびV2の値は、次の繰り返しでそれぞれV2およびV3に与えられるように、ポート91とポート92aとが枝94bを介して接続され、ポート92とポート93aとが枝95bを介して接続されている。

#### [0148]

また、ポート91aには、枝94cを介して、比較節点65によるループ終了条件の比較結果が入力されており、ループ終了条件が「真」になったときに、ポート91aに「0 | が入力される。

#### [0149]

さらに、終了を判定する節点97は、枝95cおよび96bを介して、ポート92およびポート93に接続されており、制御変数V2が「0」、かつ、V3が「1」のときにループの処理を終了するように、図示しないコントローラに指示が与えられる。

#### [0150]

ポート91および93からの制御変数V1およびV3は、それぞれ、枝94a



#### [0151]

また、ポート92からの制御変数V2は、枝95aを介して、セレクタ節点89に入力されている。制御変数V2の値は、図3に示すように、1サイクル目が「0」で、2サイクル目から11サイクル目は「1」である。したがって、1サイクル目は、セレクタ節点89において左の入力に接続されるポート64の値が出力され、2サイクル目以降は右の入力に接続される節点69の演算結果が出力される。このように、1サイクル目のみポート64に接続される外部からの初期値が選択され、それ以降は、ループ内部で演算が行われた結果が選択される。制御変数V2は、12サイクル目が「0」であるため、12サイクル目はポート64の値が選択されるが、12サイクルでループの処理が終了されるため、12サイクル目のセレクタ節点89の動作は、回路全体の動作に対して無関係である。

#### [0152]

即ち、CDFG生成手段111Aの他の実施形態として、パイプライン化されていないCDFGに対して、ステージ境界部分とグラフの枝が交差する箇所に新たにポートを追加するポート追加手段と、並列処理を示すために各ステージを横方向に配置する横方向配置手段と、横方向に配置されたCDFGに対して、繰り返し間データ転送枝を接続処理する枝接続手段と、ループ処理部にループ制御部



## [0153]

以上のような処理手順により、パイプライン化されていないループのCDFGから、ループ処理がパイプライン化されたCDFGを得ることができる。

## [0154]

このように、ループ処理がパイプライン化されたCDFGを生成し、図10に示すように、アロケーション処理、データパス生成処理、コントローラ生成処理などを行うことによって、動作記述を実現するためのハードウェアを合成することが可能である。

#### [0155]

したがって、上記実施形態 1 、 2 によれば、ループ処理をパイプライン化するときに、ループ処理部 3 のまたは 6 のを構成する各パイプライン化ステージに対して、そのパイプライン化ステージに含まれる各節点の処理が実行されるクロックサイクルと、非ループ処理が実行されるクロックサイクルとを制御する制御信号 V 1  $\sim$  V 3 を各節点 4 6  $\sim$  4 8 または 6 8  $\sim$  7 0 に出力するループ制御部 3 1 または 9 0 を設けた C D F G を作成する。これによって、動作記述からハードウェア(設計回路図)を合成する動作合成において、少ない面積の増加で C D F G 中のループ処理をパイプライン化することができる。

## [0156]

#### 【発明の効果】

以上により、本発明によれば、ループ処理および非ループ処理が含まれている動作記述から、パイプライン化されたCDFGを生成する際に、ループ処理に含まれる各節点を各パイプライン化ステージ毎に分けて複数回のループ処理の1回毎に各パイプライン化ステージの処理を並行して実行することを示すコントロールデータフローグラフのループ処理部に、ループ処理および非ループ処理のうち少なくとも非ループ処理を行わせる制御信号を各節点に出力するループ制御部を設けることによって、従来のプロローグ部とエピローグ部の非ループ処理を設けなくても、この非ループ処理を、パイプライン化したループ処理部に実行させることができ、従来のループ処理のパイプライン化方法で問題となっているハード



ウェア構成の面積増大やコスト増加を防ぐことができる。また、プロローグ部の 処理が終了する前にループ処理が終了されてしまう場合や、ループ処理の繰り返 し回数が一定でない場合であっても、誤動作を招くことなく、ループ処理のパイ プライン化を行うことができる。

## 【図面の簡単な説明】

#### 【図1】

本発明の動作合成システムの実施形態における要部構成を示すブロック図である。

#### 【図2】

図14の動作記述に対して、本実施形態1のループ処理のパイプライン化方法によりループ処理をパイプライン化したCDFGを示す図である。

#### 【図3】

図2のループ制御部の出力信号の一例を示す図である。

#### 【図4】

図2のループ制御部の出力信号の他の一例を示す図である。

#### 【図5】

図14の動作記述とは別の動作記述の一例を示す図である。

#### 【図6】

パイプライン化されないCDFGの一例を示す図である。

## 【図7】

図6のCDFGをパイプライン化する本実施形態2のパイプライン化処理手順 を示すフローチャートである。

#### 【図8A】.

CDFGのパイプライン化処理手順(その1)を示す図である。

#### 【図 8 B】

CDFGのパイプライン化処理手順(その2)を示す図である。

#### 【図8C】

CDFGのパイプライン化処理手順(その3)を示す図である。

#### 【図8D】

CDFGのパイプライン化処理手順(その4)を示す図である。

### 【図9】

(a) および(b)  $\sim$  (e) および(f) は、繰り返し間枝の接続処理例を説明するための図である。

### 【図10】

従来の動作合成方法の処理手順を示すフローチャートである。

### 【図11】

従来の動作記述の式の一例を示す図である。

#### 【図12】

図11の動作記述に対応したCDFGを表す図である。

### 【図13】

図12のCDFGのデータ構造を説明するための図である。

### 【図14】

動作記述の一例を示す図である。

#### 【図15】

従来のパイプライン化されないCDFGの一例を示す図である。

#### 【図16】

従来のパイプライン動作について説明するための図である。

#### 【図17】

従来手法によりパイプライン化されたCDFGの一例を示す図である。

### 【符号の説明】

- 30、60 ループ処理部
- 32、33、34、41、61、62 定数出力節点
- 4 2 . 4 5 . 6 3 . 6 4 . 6 3 a . 6 4 a . 7 3 . 7 4 . 8 1 . 8 2 . 8 1 a
- 、82a、83、84、83a、84a ループ処理部のポート
  - 43、65 終了条件比較節点
  - 44、67 インクリメント演算節点
  - 49、66 終了判定節点
  - 46~48 関数演算節点

- 20 プロローグ部
- 50、51 減算節点
- 29 エピローグ部
- 31、90 ループ制御部
- 35~40、91~93、91a~93a ループ制御部のポート
- 68、70 配列書き込み節点
- 69 加算節点
- 71、72、71 a、72 a、85~88、85 a~88 a 枝
- 81~84 ステージの境界部分とCDFGの枝が交差する箇所のポート
- 89 セレクタ節点
- 94a、94b、94c、95a、95b、95c、96a、96b ループ 制御部に接続された枝
  - 100 動作合成システム
  - 101、102 節点
  - 103~108 ポート
  - 111 制御部
  - 111A CDFG生成手段
  - 111B スケジューリング手段
  - 1110 アロケーション手段
  - 111D データパス生成手段
  - 111E コントローラ生成手段
  - 112 ROM
  - 113 RAM
  - 114 データベース
  - 115 操作部
  - 116 表示部

## 【書類名】 図面

## 【図1】



【図2】



# 【図3】

| サイクル          | V1 | V2 | V3 |
|---------------|----|----|----|
| 1             | 1  | 0  | 0  |
| 2             | 1  | 1  | 0  |
| 3 <b>~</b> 10 | 1  | 1  | 1  |
| 11            | 0  | 1  | 1  |
| 12            | 0  | 0  | 1  |

# 【図4】

| サイクル | V1 | V2 | V3 |  |
|------|----|----|----|--|
| 1    | 1  | 0  | 0  |  |
| 2    | 0  | 1  | 0  |  |
| 3    | 0  | 0  | 1  |  |
|      |    |    |    |  |

# 【図5】

```
j = 5;
for (i = 0; i<10; i++)
{
    a[i] = i;
    j += i;
    b[i] = j;
}</pre>
```

【図6】



# 【図7】



【図8A】



【図8B】



【図8C】



【図8D】



【図9】













【図10】



【図11】

$$x=a\times b + b\times c$$

【図12】



## 【図13】

```
struct Node
{
  int node_id;
  int in_edge[2];
  int out_edge[1];
  int op_type;
  }
struct Edge
  {
  int edge_id;
  int from_node;
  int to_node;
  }
```

## 【図14】

```
for( i =0; i <=10; i++)
{
    f(i);
    g(i);
    h(i);
}
```

【図15】



【図16】

| •          |       |      |                       |        |      |            |  |
|------------|-------|------|-----------------------|--------|------|------------|--|
| サイクル1 f(1) | f (1) |      |                       |        |      |            |  |
| #191L2     | g(1)  | f(2) |                       |        |      |            |  |
| #49113     | h(1)  | g(2) | f(3)                  |        |      |            |  |
| サイクル4      | h(2)  | g(3) | f(4)                  |        |      |            |  |
|            |       |      | /<br>                 |        |      |            |  |
|            |       |      | サイクル 9 h(7) g(8) f(9) | (7) g( | 8    | f(9)       |  |
|            |       |      | サイクル 10 h(8)          |        | 6)   | g(9) f(10) |  |
|            |       |      | サイクル 11               | p(     | h(9) | g(10)      |  |
|            |       |      | サイクル 12               |        |      | h(10)      |  |
|            |       |      |                       |        |      |            |  |

【図17】



### 【書類名】 要約書

### 【要約】

【課題】 動作記述からハードウェアを合成する動作合成において、少ない面積の増加でCDFG中のループ処理をパイプライン化する。

【解決手段】 ループ処理をパイプライン化するときに、ループ処理に含まれる各節点を各パイプライン化ステージ毎に分けて複数回のループ処理の1回毎に各パイプライン化ステージの処理を並行して実行することを示すコントロールデータフローグラフのループ処理部30に、ループ処理および非ループ処理のうち少なくとも非ループ処理を行わせる制御信号を各節点に出力するループ制御部31を設けたCDFGを生成する。

### 【選択図】 図1

### 認定・付加情報

特許出願の番号 特願2003-120600

受付番号 50300690792

書類名 特許願

担当官 小野寺 光子 1721

作成日 平成15年 4月25日

<認定情報・付加情報>

【特許出願人】

【識別番号】 000005049

【住所又は居所】 大阪府大阪市阿倍野区長池町22番22号

【氏名又は名称】 シャープ株式会社

【代理人】 申請人

【識別番号】 100078282

【住所又は居所】 大阪市中央区城見1丁目2番27号 クリスタル

タワー15階

【氏名又は名称】 山本 秀策

【選任した代理人】

【識別番号】 100062409

【住所又は居所】 大阪府大阪市中央区城見1丁目2番27号 クリ

スタルタワー15階 山本秀策特許事務所

【氏名又は名称】 安村 高明

【選任した代理人】

【識別番号】 100107489

【住所又は居所】 大阪市中央区城見一丁目2番27号 クリスタル

タワー15階 山本秀策特許事務所

【氏名又は名称】 大塩 竹志

### 特願2003-120600

## 出願人履歴情報

識別番号

[000005049]

1. 変更年月日 1990年 8月29日

[変更理由]

新規登録

住 所 大阪府大阪市阿倍野区長池町22番22号

氏 名 シャープ株式会社